﻿#region 版权声明





//



// 
// 代码开源主要用于解决大家在学习和研究协议过程中遇到由于缺乏代码所带来的制约性问题。
// 本代码仅供学习交流使用，大家在使用此开发包前请自行协调好多方面关系，
// 不得用于任何商业用途和非法用途，本人不享受和承担由此产生的任何权利以及任何法律责任。
// 
// 本源代码可通过以下网址获取:
// http://www.vckers.com
//
// Copyright @ 2009-2010  vckers.com.  All Rights Reserved.   
// Framework: 3.5

  

 
//   
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation; either version 2 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details. 
  
#endregion

using System;
using System.Collections.Generic;
using System.Text;
using System.IO;
using TS.QQ.Utils;

namespace TS.QQ
{
  public class QQLog
    {
      private object obj=new object();
      private FileStream fs;
      public QQClient QQClient { get; private set; }
      public string FileName
      {
          get;
          set;
      }
      public QQLog(QQClient qqClient)
      {
          this.QQClient = qqClient;
          string directory = Util.MapPath("/Log/" + qqClient.QQUser.QQ);
          this.FileName = Path.Combine(directory ,System.DateTime.Now.ToString("yyyy-MM-dd") + ".txt");
          if (!Directory.Exists(directory))
          {
              Directory.CreateDirectory(directory);
          }
          
      }

      public void Log(string msg)
      {

          lock (obj)
          {     
              StreamWriter sw = null;
              fs = new FileStream(this.FileName, FileMode.OpenOrCreate, FileAccess.ReadWrite, FileShare.Read);
              fs.Seek(0, SeekOrigin.End);
              sw = new StreamWriter(fs, System.Text.Encoding.Default);
              string LineText = DateTime.Now.ToString() + ", " + msg;
              sw.WriteLine(LineText);
              sw.Close();

              sw = null;
              fs.Close();
              fs = null;
          }
          

      }


    }
}
